SQL UNION Operator

दो या दो से अधिक SELECT कथनों के परिणाम-सेट को संयोजित करने के लिए UNION ऑपरेटर के बारे में जानें

SQL UNION Operator क्या हैं?

UNION ऑपरेटर का उपयोग दो या दो से अधिक SELECT स्टेटमेंट के परिणाम-सेट को संयोजित करने के लिए किया जाता है।

यूनियन ऑपरेटर स्वचालित रूप से परिणाम सेट से डुप्लिकेट पंक्तियों को हटा देता है।

यूनियन के लिए आवश्यकताएँ:

  • UNION में प्रत्येक SELECT स्टेटमेंट में कॉलम की संख्या समान होनी चाहिए
  • कॉलम में भी समान डेटा प्रकार होने चाहिए
  • प्रत्येक SELECT स्टेटमेंट में कॉलम एक ही क्रम में होने चाहिए

यूनियन सिंटैक्स

SELECT column_name(s) FROM table1
UNION
SELECT column_name(s) FROM table2;

नोट:

परिणाम-सेट में कॉलम नाम आमतौर पर पहले SELECT स्टेटमेंट में कॉलम नाम के समान होते हैं।

प्रदर्शन डेटाबेस

इस अभ्यास में हम प्रसिद्ध नॉर्थविंड मॉडल डेटाबेस का उपयोग करेंगे।

नीचे "ग्राहक" तालिका से एक चयन दिया गया है:

ग्राहक तालिका

+------------+--------------------------------+----------------+-------------------+----------+------------+---------+
| CustomerID | CustomerName                   | ContactName    | Address           | City     | PostalCode | Country |
+------------+--------------------------------+----------------+-------------------+----------+------------+---------+
| 1          | Alfreds Futterkiste            | Maria Anders   | Obere Str. 57     | Berlin   | 12209      | Germany |
| 2          | Ana Trujillo Emparedados...    | Ana Trujillo   | Avda. Constitución| México   | 05021      | Mexico  |
| 3          | Antonio Moreno Taquería        | Antonio Moreno | Mataderos 2312    | México   | 05023      | Mexico  |
+------------+--------------------------------+----------------+-------------------+----------+------------+---------+

और "आपूर्तिकर्ता" तालिका से एक चयन:

आपूर्तिकर्ता तालिका

+------------+-----------------------------+-------------------+-----------------+-------------+------------+---------+
| SupplierID | SupplierName                | ContactName       | Address         | City         | PostalCode | Country |
+------------+-----------------------------+-------------------+-----------------+-------------+------------+---------+
| 1          | Exotic Liquid               | Charlotte Cooper  | 49 Gilbert St.  | London       | EC1 4SD    | UK      |
| 2          | New Orleans Cajun Delights  | Shelley Burke     | P.O. Box 78934  | New Orleans  | 70117      | USA     |
| 3          | Grandma Kelly's Homestead   | Regina Murphy     | 707 Oxford Rd.  | Ann Arbor    | 48104      | USA     |
+------------+-----------------------------+-------------------+-----------------+-------------+------------+---------+

SQL UNION उदाहरण

निम्नलिखित SQL कथन "ग्राहक" और "आपूर्तिकर्ता" तालिकाओं से शहर (केवल विशिष्ट मान) लौटाता है:

उदाहरण

SELECT City FROM Customers
UNION
SELECT City FROM Suppliers
ORDER BY City;

निष्कर्ष

City
Ann Arbor
Berlin
London
México
New Orleans

नोट:

यदि कुछ ग्राहकों या आपूर्तिकर्ताओं का शहर एक ही है, तो प्रत्येक शहर को केवल एक बार सूचीबद्ध किया जाएगा क्योंकि UNION केवल अद्वितीय मानों का चयन करता है। डुप्लिकेट मानों का भी चयन करने के लिए UNION ALL का उपयोग करें!

कहां के साथ एसक्यूएल यूनियन

निम्नलिखित SQL कथन "ग्राहक" और "आपूर्तिकर्ता" तालिकाओं से जर्मन शहरों (केवल विशिष्ट मान) को लौटाता है:

उदाहरण

SELECT City, Country FROM Customers
WHERE Country='Germany'
UNION
SELECT City, Country FROM Suppliers
WHERE Country='Germany'
ORDER BY City;

एक और यूनियन उदाहरण

निम्नलिखित SQL कथन सभी ग्राहकों और आपूर्तिकर्ताओं को सूचीबद्ध करता है:

उदाहरण

SELECT 'Customer' AS Type, ContactName, City, Country
FROM Customers
UNION
SELECT 'Supplier', ContactName, City, Country
FROM Suppliers;

निष्कर्ष

Type
ContactName
City
Country
Customer
Maria Anders
Berlin
Germany
Customer
Ana Trujillo
México
Mexico
Customer
Antonio Moreno
México
Mexico
Supplier
Charlotte Cooper
London
UK
Supplier
Shelley Burke
New Orleans
USA
Supplier
Regina Murphy
Ann Arbor
USA

टिप्पणी:

ऊपर "AS प्रकार" - यह एक उपनाम है। SQL उपनाम का उपयोग किसी तालिका या स्तंभ को अस्थायी नाम देने के लिए किया जाता है। उपनाम क्वेरी की अवधि तक सीमित है। इसलिए, यहां हमने "प्रकार" नामक एक अस्थायी कॉलम बनाया है, जिसमें सूचीबद्ध है कि संपर्क व्यक्ति "ग्राहक" है या "आपूर्तिकर्ता"।

यूनियन दृश्य प्रतिनिधित्व

ग्राहकों के शहर

Berlin
México
México
London
UNION

आपूर्तिकर्ताओं के शहर

London
New Orleans
Ann Arbor

यूनियन परिणाम

Ann Arbor
Berlin
London
México
New Orleans

टिप्पणी:UNION स्वचालित रूप से डुप्लिकेट मान हटा देता है। हालाँकि "मेक्सिको" और "लंदन" दोनों तालिकाओं में हैं, वे केवल अंत में दिखाई देते हैं।

यूनियन आवश्यकताएँ विस्तार से

स्तंभों की संख्या

प्रत्येक SELECT स्टेटमेंट में कॉलम की संख्या समान होनी चाहिए

-- ठीक है तालिका 1 से नाम, शहर चुनें संघ तालिका 2 से नाम, शहर चुनें --गलत तालिका 1 से नाम, शहर चुनें संघ तालिका 2 से नाम चुनें

डेटा के प्रकार

कॉलम में समान डेटा प्रकार होने चाहिए

-- ठीक है तालिका 1 से नाम, आयु चुनें संघ तालिका 2 से उत्पाद, मात्रा चुनें --गलत तालिका 1 से नाम, आयु चुनें संघ तालिका 2 से उत्पाद, दिनांक चुनें

स्तंभ क्रम

कॉलम एक ही पंक्ति में होने चाहिए

-- ठीक है तालिका 1 से प्रथम नाम, अंतिम नाम चुनें संघ तालिका 2 से प्रथम नाम, अंतिम नाम चुनें --गलत तालिका 1 से प्रथम नाम, अंतिम नाम चुनें संघ तालिका 2 से अंतिम नाम, प्रथम नाम चुनें

अभ्यास

निम्नलिखित SQL कथन में क्या त्रुटि है?

SELECT CustomerName, City FROM Customers
UNION
SELECT SupplierName FROM Suppliers;
अमान्य तालिका नाम
✗ ग़लत! तालिका के नाम सही हैं
स्तंभों की संख्या मेल नहीं खाती
✓ ठीक है! पहले SELECT में 2 कॉलम हैं और दूसरे SELECT में केवल 1 कॉलम है
गलत कीवर्ड उपयोग
✗ ग़लत! UNION कीवर्ड का सही उपयोग किया गया है
डेटा प्रकार मेल नहीं खाते
✗ ग़लत! सबसे पहले कॉलमों की संख्या जांची जानी चाहिए